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A system for processing fasfomatloD contained in a col^^ 
of text-tesed tef ormatlw sooxces eoqdoys associative and Knguts* 
tie expsnsioa of inpnt words In vi^dcb associathm expansion b fim 
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dance with rdated mMpbdoglcal and itostic mles. The system 
aotianatk^ generates and iqKfates a linguistic ta»wle^ 
each language to be processed by analyzhig a XrcOf of teoit In 
each tanguage. the system also automatically indexes &e coUec- 
tion of text-based Inforaution sowccs tt> be scaicfaed. A method Is 
provided to expand a word or term In asuppcnted language using 
a two^bnenslonal C2D) expansion matrix pniWdlng great flexibil- 
ity^ higb accuracy and low noise ou^ut The 2D expansion matrix 
Inchtdes an associative dbnensloo that utilizes thesauri, databses xA 
saved queries and otfier associated faifiarmadca soorces. in which 
words are related to other words by meaning and relations, and a 
Im^iistlc dbnension whicfa utlUzes rccognllion-granunais, In whidi 
words STB related to other wosdi by combined roles for morpholog- 
ical and phooedc varfttka. 
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A SYSTEM, SOFTWARE AND METHOD FOP l O CATING INFORMATION IN A 
COLT.KCTION OF TEXT^BASED INFO RMATION SOURCES 

5 BACKGROUND 

1. Field of the Invention 

The present invention relates generally to the field of information retrieval. More 
particularly, the present invention relates to information management systems and computational 
linguistic systems for finding information related to a user-input query, in a collection of texl- 
10 based information sources. 

2. Discussion of Related Art 

In the Information Age, the ability to manage enormous volumes of information 
efficiently and find needed information quickly has become a driving force in all human 

1 5 endeavors. Early in the development of infonnation management systems, the capability to 
process large volumes of free-fomi text documents and other text-based infonnation sources was 
severely limited. Therefore information specialists developed various types of database 
management systems and searchmg systems based on strictly controlling how data may be 
received, stored, and referred to. However, as the volimie and nature of the infonnation which 

20 must be handled by such systems has expanded, conventional database management systems 
have been unable to keep pace. 

In conventional database management systems, data is stored in a strictly structured 
environment Such systems may be based upon tables of records or spreadsheet models, for 
example. Such systans may be flat or may be relational with respect to how records in the 

25 database are associated with each other. However, conventional database management systems 
generally require structured records in which one or more fields may be searchable, i.e. are key 
fields. Furthermore, it is desirable that such key fields use terms, e.g. numbering systems, labels, 
etc., in a consistent manner which facilitates searching with known query values, i.e. 
combinations of numbers, labels, etc. 

30 In order to locate information within general text-based information sources, so-called 

full-text searching has developed. Full-text searching of a collection of text-based information 
sources, such as English-language documents stored in a computer system, pennits a user to 
write a query containing terms known to be used in relevant documents. The collection of 
documents is first fiilly indexed and the words of the documents in the index are compared with 
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the query terms. In the simplest form of this type of system, an exact match between a query 
term and an index entry must be found in order to identify a relevant document. Spelling errors, 
word variants, etc. will tend to prevent finding all relevant doctunents. A technique called wild- 
carding may be used to partially alleviate this problem, but many irrelevant documents, refenred 
5 to as "noise," often turn up when wild-carding is used. An example of the use of wild-carding is 
where a user query term includes only what the user has identified to be a word base of a relevant 
term, such as "comput*" for the concept of "compute," "computer," "computing," 
"conqjutation," etc.» where indicates the portion of the term which has been left out. 

Modem, conventional, full-text searching systems have been developed which have a 
10 much higher level of sophistication. For example, Pinkas, G., Natural Language Full-Text 
Retrieval System, Master's Thesis, University of Jerusalem, 1985, discloses a system which 
automatically expands a user's query to include additional relevant terms in a manner more 
noise-free than simple wild-carding. The Pinkas system: (1) receives a user query composed of 
query-words and boolean operators; (2) expands the query linguistically, i.e. by referring to a 
15 pre-processed database of morphological and phonetic information; (3) e3q>ands the query 

assodativdy, i.e. by referring to a database of associated sub-queries; and (4) merges the results 
of steps 2 and 3 above. Morphological expansion draws in the infix variations of the query 
terms, while phcmetic expansion brings in terms that may be generated by misspelled vowels 
(e.g. recieve receive). Associative expansion draws into the query related terms as pre-defined 
20 by the user in the form of sub-queries being associated with a specific query-word (e.g. to 

associate the acronym "USA" with its full wording, one creates an association between the word 
"USA" and a query applying a boolean "and" operation to the foUovmig 4 words: "United", 
"States", "or, '^America", restricted to a proxunity of 1 word distance. Thus a comprehensive 
expanded query is generated to cover the many different words that may conceptually be related 
25 to user's original query. Some variation in the level of morphological expansion and the level of 
phonetic expansion to be performed is available to the user by selection of expansion parameters. 

However, this process of morphological and phonetic expansion suffers from many 
inefficirades: it fails to recognize the fimdamental difTerences between different "word-bases" 
such as morphological stems and phonemes, therefore it misses many relevant linguistic 
30 permutations affected by both mechanisms, and at the same time it generates a large amount of 
noise, i.e. false-positives, due to the combinatorial effect of combining both mechanisms. 
Moreover, this process also is fairiy limited to recognizing and expanding single words, and even 



wo 97/38376 PCT/IB97/00748 

then the interaction between the associative expansion and the linguistic expansion is fairJy 
limited to a trivial merge of both results, having not shared a conceptual foundation that allows a 
mutual feedback (e.g, the query-word "airplane" expands to ("airplane" or "airplanes** or 
"aircraff 0 but not to "aircrafts". 

5 In conventional systems, query expansion depended upon a set of linguistic rules which 

were developed by an expert in the language to be processed. The set of linguistic rules vras both 
extensive and relatively inflexible, since as many characteristics of the input language as possible 
had to be accounted for before processing any text-based information sources. Development of 
tiie linguistic rules for each language to be processed was a very labor-intensive and time- 

10 consuming task. 

Finally, conventional systems are known which require manual indexing of text sources, 
as well as which index text sources automatically. Conventional indexes simply map a word 
found in the text sources to a location at which the word is found. Manual full-text indexing is 
extremely time-consuming and error-prone. Keyword indexing is subjective and also somewhat 
15 error-prone. 



SUMMARY OF THE INVKNTTON 

Therefore, it is a general aim of the present invention to solve the problems noted above 
with respect to the prior art Aspects of the present invention solving the problems of the prior 
art include at least a system, software and a method for processing information contained in a 
collection of text-based information sources. 

The system may include a computer or data processor and software structured as one or 
more software modules, units or functions which when executed in a specified order by the 
computer or data processor perform the desired infomaation processing task. One or more 
software modules, units or functions may be made available in conventional manner as either 
compile-time or nm-time library entries which may be referred to by a software program which 
is written in a manner to be aware of such a library. The present invention fiirther provides a 
method to process query^oncepts and transform them to an expanded/improved query using an 
expansion matrix providing great flexibility, high accuracy and low noise output. 

According to one aspect of the invention, there may be provided a text-based information 
processing system, comprising an automatic linguistic knowledge base generator having an input 
receiving a collection of text-based information sources and which produces a linguistic 
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knowledge base; an index generator having inputs receiving a collection of text-based 
information sources and the linguistic knowledge base and which produces an index of the 
received text-based information and further which updates the linguistic knowledge base to 
reflect the inputs to the index generator and maintain correlation between the index and the 
5 linguistic knowledge base; a query processor having inputs receiving a query composed by an 
operator, the linguistic knowledge base, the md^ and a thesaurus and which produces a list of 
locations in the collection of text-based information sources relevant to the query. The text- 
based mfomiation processing system may be subject to numerous modifications and variations. 
For example, the automatic linguistic knowledge base generator, the automatic index generator 
to and the query processor may be embodied in various ways. 

In accordance with another aspect of the invention, in a text-based information processing 
system, an automatic linguistic knowledge base generator may comprise a parser, receiving an 
input stream of terms and producing individual tenms; a language recognizer connected to 
receive the individual terms from the parser and vMoh produces an output indicative of a 
15 language to v^ich each individual term belongs; a nomializer connected to receive the individual 
terms and further to receive linguistic rules for the language indicated by the output of the 
language recognizer and producing normalized terms; and a linguistic expander connected to 
receive the legal individual trams and producing entries stored in the linguistic knowledge base. 
In accordance vwth yet another aspect of the invention, in a text-based information 
20 processing system, an automatic indexer may comprise a parser, receiving an input stream of 
terms and producing individual tmns; a language recognizer connected to receive the individual 
terms from the parser and which produces an output indicative of a language to which each 
individual term belongs; a normalizer connected to receive the individual tenns and further to 
receive linguistic niles for the language mdicated by the output of the language recognizer and 
25 producing nonnalized terms; and an index entry generator connected to receive the legal 

individual terms and producing entries stored in the index when the terms have not previously 
been indexed and modifying an cxistmg index entry when the terms have previously been 
indexed. 

• Finally, in accordance with yet another aspect of the invention, in a text-based 
30 information processing system, an expansion unit for expanding terms in a language may 
comprise an associative expander having an input receiving a term and having an output 
representing the term and at least one associated term found by the associated expander making 
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reference to a thesaurus; and a linguistic expander having an input connected to the output of the 
associative expander and having an output representing the input of the linguistic expander and 
at least one term linguistically related to the input of the linguistic expander and found by 
reference to a linguistic knowledge base for the language. 

The nonnalizers recited above may be constructed of two units. The first normalizer unit 
may be connected to receive the individual tenns and the linguistic rules and producing terms 
from which illegal characters have been removed; and the second normalizer tinit may then be 
connected to receive the terms firom which illegal characters have been removed and the 
linguistic rules and which produces normalized terms including word stems found by applying 
the linguistic rules to the terms from which illegal characters have been removed. 

The present invention will be better understood by reading the Detailed Description of at 
least one illustrative embodiment of the invention, in connection with the attached drawing. 

BRIEF DESCRIPTION OF THE DRAWINGS 

In the drawings, in vAtiob like referaice designations indicate like elements. 
Fig. I is a schematic block diagram of a computer or data processing system on which the 
present invention may be practiced; 

Fig. 2 is a schematic block diagram of the memory of Fig. 1 ; 

Fig. 3 is a flow chart of automatic linguistic knowledge base generation; 

Fig. 4 is a flow chart of automatic index generation; 

Fig. 5 is a flow chart of query expansion; and 

Fig. 6 is a flow chart of an information retrieval system including the features illustrated 
in Figs. 3-5. 

DETAILED DF^CRIPTfOfiT 
In order to better understand the following detailed description, reference should be made 
to the following definitions. In this discussion a "language" is considered to be any organized 
system of tokens, which have symbolic meaning. For convenience, the tokens are referred to 
hereinafter as "words" or "terms,*' since the most common types of languages dealt with by text- 
based information systems are natural human languages composed of words or combinations of 
words, i.e. temis, which are understood to have specific meanings by humans. Thus, the terms 
*^vo^ds•* and "terms" are intended to encompass word phrases in those instances where a word 
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phrase may in fact be a token having a meaning independent of its sub-units, keywords in those 
instances where a word or word-phrase has a specific context/importance, and artificial words 
such as acronyms and short-cuts. A "word base" is the base portion of a word which remains 
after removing all prefixes and suffixes of the word which modify the meaning or part of speech 
5 of the word root appropriately for the context in which the word may be used. The term 

*Hhesaurus" as used herein refers to a database of terms, words and/or word bases, in which each 
term, word or word base is associated in the database with other terms, words and word bases 
having a defined relationship such as morphological proximity, phonetic similarity, similar 
meaning (synonyms), nearly opposite meaning (antonyms), broader meaning, narrower meaning, 
10 related Xtm in a specific context, etc. The database may be navigated or searched on the basis of 
the terms, words and/or word bases stored therein. 

Languages considered here have known linguistic rules for the morphological and 
phonetic variations which words may undergo. For example, the morphological rules of a 
language may defme bow a plural is formed from a singular noun, by changing the shape of the 
)5 word, i.e. adding a final "s" in English, while the phonetic rules may represent the common 

variations in spelling resulting from user spelUng errors. A table, file or database may be used by 
a software program to hold a list of such linguistic mles. 

Generally, languages also include words M*ich do not follow the linguistic rules of the 
language. For example, the English language morphological rule for generating the past tense of 
20 a verb does not apply to the verb 'to go," which becomes *Svenf * rather than the nonsensical 
"goed." Therefore, exceptions to the rules may be held by a software program in a table of 
exceptions, so that words which do not obey the rules may be handled as accurately as words 
which do obey the rules. In the context of the present invention, a "linguistic knowledge base" is 
developed by applying the linguistic rules and the one or more tables of exceptions or irregular 
25 forms to a large body of textual infomaation to produce an efficient, adaptable and flexible 
representation of the variations of word bases which produce meaning, particulariy in natural 
languages, but also in language generally. The "linguistic knowledge base** is a table, list or 
database of word bases and related words. Related words are those words which when analyzed 
under the linguistic mles for the language are determined to have the same word base. 
30 The present invention is constructed in the context of computer systems and data 

processing systems. An overview of such systems is given in connection with the block diagram 
of Fig. 1 . A computer system or data processing system generally includes a processor 1 01 . a 
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memory 103, one or more input devices 105, and one or more output devices 107, all 
interconnected through an interconnection mechanism 109. Many variations of this basic plan 
are possible. For example, viable systems may lack input devices 1 05 and output devices 1 07, 
communicating entirely through interactions with the memory 103 by external devices (not 
shown). Also, distributed computer systems and data processing systems are contemplated as 
falling within this basic plan. The interconnection mechanism 109 may be an internal system 
bus of a penonal computer or may be the Internet, through which a processor 101 interacts with 
a database stored on a remote memory 1 03. Other variations will be evident to those skilled in 
this art 

Memory 103 may be classified into two categories useful to this discussion, long term 
memory (also called non-volatile memory), and short term memory (also called volatile 
memory). These two types of memory are often both used in computer systems and data 
processing systems, as shown in Fig. 2. Volatile memory 201 such as integrated circuit random 
access memory (RAM) is often used in close physical proximity to the processor 101 because the 
technologies in which such volatile memory 201 is most readily realized produce fast access 
times, such as are desirable to support fast processors 101. Non-volatile memory 203 is often 
used to store massive quantities of data for longer periods of time because it can be more cheaply 
constructed tiian volatile memory of a similar capacity. Non-volatilc memory 203 is often 
implemented as magnetic or optical disk or tape storage units, which provide a ftxrther advantage 
of data and software program interchange betvi^en different computer or data processing 
systems. As such, non-volatile memory 203 may be a softvrarc product disk on which are 
recorded signals representing instructions, which when executed by a processor 101 cause the 
computer or data processing system to perform a special purpose function. Software embodying 
aspects of tiie present invention may be recorded on such a non-volatile memory 203 for 
distribution by a manufacturer, for archival purposes, for access through a volatile memory 201 
by a processor lOL etc. 

In accordance with various aspects of the present invention, there may be constructed a 
system for searching through and locating information in a collection of text-based information 
sources. In accordance with various aspects of the invention, a linguistic knowledge base is first 
generated. Then, the collection of text-based information sources is indexed. A user next inputs 
a query defining the information sought The query is expanded according to selected 
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associative and linguistic rules, using a thesaurus and the linguistic knowledge base. Finally, 
information is identified which matches the various expanded query terms. 

The thesaurus, linguistic knowledge base and index may be stored in one or more 
computer files to which the system has access through memory 103. 
5 The aspects of the invention connected with automatic generation of the linguistic 

knowledge base, automatic generation of the index and query expansion are next described in 
detail. 

I Automatic Generatio n »^ Linguistic Knowledge BaSC 

According to one aspect of the invention, software as shown in Fig. 3 is provided which 
10 when executed by a suitable data processing system will automatically generate the linguistic 
knowledge base from an input body of text based information sources. For example, according 
to this aspect of the invention, a collection of English language documents may be processed to 
generate an English language linguistic knowledge base. 

A small set of linguistic rules 301, including a list of exceptions 302 to the linguistic rules 
I $ for a language, e.g. English, is first generated by statistical analysis of a large body of text based 
information. This small set of rules includes: 

a list of irregular words and word bases in the language, i.c. the list of exceptions noted 

above; 

a word normaliTation table specifying legal characters in the language, i.e. the alphabet of 
20 the language, and legal character positions in the language, eg. special rules concerning 

characters which can only appear at specific locations within a word; 
a prefix and suffix list specifying legal prefixes and legal sufSxcs in the language; and 
letter-to-sound rules for bodi ordinary words and proper names in the language. 
This set of rules 301, including the list of exceptions 302, is then used to analyze a body of text 
25 based information sources 303, to generate a linguistic knowledge base 305 specifically adapted 
from the body of text based information sources 303. The body of sources 303 may be selected 
to be sources from a particular field of endeavor in which future queries are expected to be made, 
for example. This will result in a linguistic knowledge base better able to cope with the specifics 
of that particular field of endeavor. The body of sources 303 firom which the linguistic 
30 knowledge base 305 is derived may not be the same body of sources which is ultimately to be 
searched. However, automatically generating the linguistic knowledge base 305 from the body 



wo 97^8376 PCT/IB97/00748 

-9- 

of sources to be searched has the advantage that the linguistic knowledge base 305 so produced is 
particularly well adapted to the body of sources to be searched. 

Autonaatic generation of the linguistic knowledge base 305 proceeds as follows. The 
body of text based information sources 303 forms an input stream of text 304 to the system. This 
input stream 304 is first parsed into words and terms 307 in accordance with either fixed word 
recognition rules or word recognition rules specific to one or more languages. The language of 
each of the words parsed from the input stream is then recognized 309. Once the language of a 
word has been^recognized the word may be normalized 311 according to the linguistic rules 301 
for the language. Irregular words may also be recognized at this point, since known irregular 
words are already in the list of irregular words 302 and hence need no further processing. The 
system may also identify as potential new irregular words, those words meeting some rule-based 
criteria. Those previously unknown irregular words may be identified to a human operator for a 
determination of whether they should be added to the list of irregular words. Regular words are 
linguistically expanded 313 before being added to the linguistic knowledge base 305 such diat 
word bases are stored in the linguistic knowledge base 305 along with a list of related words 
firom the body of sources 303. Linguistic expansion 313 is discussed in greater detail below. 

The step of parsing 307 the input stream 304 into sentences and words takes place 
according to the following pseudo-code: 
Load segmentation rules; 

segment input stream into sentences Euid words using segmentation 
rules ; 

for each sentence 

{ 

for each word 
{ 

if language not explicitly specified, identify 

word's language 
end if; 

normalize word; 

return word and word's coordinates; 
return rest of input stream; 
} next word; 
} next sentence. 

Normalization is performed as follows. Normalization identifies and removes garbage characters 
from the words of the input stream 304. 



10 
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For each character of an input word 
{ 

if the character is illegal 
{ 

set normalization status according to the character; 

} . 

else 

{ 

translate the character to the internal alphabet; 
add the translated character to the output word; 

1 

. } next character. 



Finally, new keys arc added to the linguistic knowledge base 305 by the following procedure. 

15 If language not explicitly specified 

identify the language of the input word; 
for each recognition type 

•analyze word according to recognition type and level; 
20 search for analysis results in key table; 

if result is found in key table 

{ 

next recognition type; 

} 

25 else 

( 

insert key and word into table; 
if key has a legal sub-key 

30 ^ activate linguistic correction mechanism; 

) 

} 

} next recognition type. 

35 Two useful recognition types subject to analysis as indicated in the above pseudocode are 

morphological and phonological. The morphological analyzer of the described embodiment 
functions in accordance with the following procedure. The morphological analyzer receives a 
list of valid prefixes and suffixes in the language identified for the input word. 
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Start at end of word; 
strip next substring from end; 
for each substring of word 
{ /* search for prefix*/ 
5 if substring is found to be a prefix in the identified 

language 

{ 

strip prefix - create initial stem; 
/* search for suffix */ 
10 start at beginning of stem; 

strip next substring from beginning of stem; 
for each substring of stem 

{ 

if substring is found to be a suffix 
>5 { 

Strip suffix - create stem; 
return stem; 
} endif; 
} next substring; 
20 } endif; 

} next sxibstring. 

The phonetic analyzer converts each word into a phonological representation of the word on the 
basis of letter to sound rules. Words having similar or same phonological representations may be 

25 considered to be related by their phonetic morphology. 

When the above processes have been completed for the body of text based information 
sources 303 initially presented, a Imguistic knowledge base 305 for the languages of the text in 
the body of sources 303 will have been automatically generated When new text based 
information sources are added to the system, they arc also processed as above. Thus, new 

30 sources mcrease the knowledge and accuracy of the linguistic knowledge base 305 through the 
addition of new information to the linguistic knowledge base 305, as well as through the 
linguistic confection mechanism which corrects the contents of individual entries in the linguistic 
knowledge base 305 according to new infonnation. The learning procedure which embodies the 
linguistic correction mechanism is as follows. 
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Open a new table entry for a new correct key; 

get the list of words in the body of a previous key entry; 

for each vord 

{ 

re-analyze word; 

if analysis results match the new correct key 

^ delete word from body of previous key entry; 
add word to body of new correct key entry; 

) 

} next word; 

if previous key entry ie empty 
delete previous key entry. 

When the system detects inconsistencies between the contents of the linguistic knowledge base 
305 and a newly presented text source, the affected word base and list of related words may be 
automatically, or at the direction of a human operator, reanalyzed and updated in accordance 
with the newly presented information and the above procedure. Thus, the system constantly 
leams about each language processed and updates the affected linguistic knowledge bases. 
II Aiitnmatir fi^ifimtiftn of t hft Index CoTrelnted with the LinPUiStiC KnOVfledBe BaM 

In addition to the linguistic knowledge base 305, the retrieval systwn according to 
another aspect of the present invention shown in Fig. 4 automatically generates an index 401, 
whereby text based infoiroation may be found by reference to the index 401 . Automatic 
generation of the index 401 is accompanied by updating of the Ungiustic knowledge base 305, so 
that the contents of the linguistic knowledge base 305 reflects the relevant tenns contained in the 
body of text based infoiroation sources 303 and is thus correlated writh the index 401 . The index 
401 simply relates words actually found m the body of text based information sources 303 to 
locations within the body of sources 303. It is preferred that the location be defined 
hierarchicaUy. For example, the location may be represented hierarchically by a document 
number, section number, sentence number and position number. Other hierarehical location 
identiScaiion schemes may be used, as seen fit by those skilled in this art 

In accordance with a preferred embodiment of the invention, the index 401 is assisted by 
the linguistic knowledge base 305. The index 401 includes only words and tenns actually 
occurring in the text-based infonnation sources 303. The linguistic knowledge base 305 relates 
i word bases derived from the words actually occurring in the text-based information sources 303 
to lists of related words. During retrieval, which is explained below, the system retrieves an 
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entry from the linguistic knowledge base 305 which is then used to reference one or more index 
entries. 

Automatic generation of the index 401 proceeds as follows. The body of text based 
information sources 303 forms an input stream of text 304 to the indexing subsystem. This input 
5 stream 304 is first parsed into words and terms 307 in accordance with the word recognition 
rules. The language of each of the words parsed from tlie input stream is then recognized 309. 
Once the language of a word has been recognized 309 the word may be normalized 3 1 1 
according to the linguistic rules 301 for the language. An index entry is then generated 403 for 
each new normalized word. If the normalized word already has an entry in the index 401, then 

10 the location of the current occurrence of the word is added to the previous entry. 

At substantially the same time as the above process, the linguistic knowledge base 305 is 
continuously kept correlated with new and modified entries produced in index 401. Each 
normalized word is reduced to its word base 405 in accordance with the linguistic rules of the 
language of the word. The word base and related word is then added to the linguistic knowledge 

15 base file 407, if not ahready present The user may also specify that related words include 

various types of expansions of the word bases. If expansions are included, e^qjansion of the word 
base is performed before storing the word base and related words in the linguistic knowledge 
base file 305. When indexing of a body of text based information sources 303 is complete, die 
linguistic knowledge base 305 is correlated with the index 401 and reflects the relevant terms 

20 contained in the body of text based infomiation sources 303. 
PI. Query Expansion 

Query expansion is performed in accordance with a. third aspect of the invention, showoi 
in Fig. 5. Since a query may contain more than one word or term, -word recognition is first 
performed as above. 

25 The words and terms identified by the word recognition task may further be normalized. 

That is, they may be converted to a base form, if desired. By making reference to a thesaurus 
and linguistic rules, spelling errors may be removed, different lexical forms of acronyms and 
short-cuts may be recognized, etc. 

Each recognized word in the query may then be expanded using a 2D expansion matrix. 

30 The 2D expansion matrix is one way of defining the expansion space in which an input word 
may be represented. The dimensions of this space are associative and linguistic. The associative 
dimension is based upon the meaning of words/word-bases in the language to be processed. In 
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the described embodiment of the invention, the associative dimension is defined by one or more 
thesauri 501 relating words and tern\s to their synonyms, broader terms, narrower terms and 
other relations. Each thesaurus 501 includes a database of terms along with conceptually related 
terms. The thesaurus is searchable by term. Thus, each thesaurus entry contains an entry key 

5 which is a list of searchable temis. Each entry key has associated therewith one or more terms 
conceptually related to the entry key. such as synonyms, broader terms, narrower terms, 
associated terms, antonyms, etc. The inclusion of any one or more categories of association is 
optional. Furthermore, each entry term may optionally have associated therewith a convenUonal 
dictionary definition and usage guide, as well as a query string into which the entry key may be 

10 translated when required. Thus, the thesaurus is a list of entries, wherein each entry has a 

structure substantially as follows: 

KEYWORD: (in the form ofnatural language phrase or term) Used as an entry key. 

DESCRIPTION (optional): A description of keyword meaning and usage (as in 
encyclopedic dictionaries). 
15 • QUERY: A complete query .statement in an underiying full-text query language tiiat the 
keyword is translated to when required (optional). (E.g.. KEYWORD "USA" - QUERY 
^United A>fD States AND of AND America".) If a translation of the keyword to a 
complete query statement is not supplied explicitiy, a default translation is applied to the 
keyword. 

20 • RELATIONS 

SYNONYMS: A list of keywords synonymous with the KEYWORD that 

con^rise a concept or descriptor. 

BROADER TERMS 

NARROWER TERMS 

25 • ASSOCIATIONS 

OTHER 

All of these features may be used by an operator to determine whether associative expansion is 
having a desired effect. 

The linguistic dimension of tiiis expansion space is based upon the linguistic knowledge 
30 base 305 of the language to be processed. As discussed above, the linguistic knowledge base is 
built automatically from the actual corpora of tiie text-based information sources, independent of 
manually crafted linguistic dictionaries, and not being restricted to "legal" or "proper" words. In 
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this embodiment of the invention, linguistic expansion grammars of morphology and phonetics 
are supported. 

The expansion task performs 2D expansion in substantially two main steps. First an 
associative expansion is perfomied at step 503, in which each input word of an input query 505 

5 is expanded to a list of words 507 including words having defined relations to the input word. 
The associated words are found by making reference to the thesaurus 501 . This expanded list of 
words 507 becomes the input on which linguistic expansion 509 is perfomied in both the 
moiphoiogical and phonetic dimensions, simultaneously. The morphological and phonetic 
expansion is controlled by making reference to the linguistic knowledge base 305. The linguistic 

10 expansion 509 may be controlled by expansion parameters 51 1 supplied by the user to include 
varying degrees of morphological expansion and phonetic expansion, ranging for both 
dimensions fiom no expansion in that dimension to full expansion in that dimension. By 
performing the morphological and phonetic expansions as a single, linguistic expansion step 509, 
expansion strategies for morphology and phonetics may be intelligently related. The 

1 5 relationships between the expansion dimensions are defined in the linguistic knowledge base 305 
for the language. Thus, a rule for morphological expansion may define a morphological 
variation which changes depending upon the phonetic properties of the ii^jut word or the 
expanded result As a result, less noise is generated in the expanded output because relating the 
morphological and phonetic dimensions as a single linguistic plane eliminates morphological 

20 variants \^ch are jAonetically unacceptable under the totality of the linguistic rules, and vice 
versa. 

rV. A Complete Text Retrieval System 

It can now be seen that using the software described above a retrieval system may be 
constructed as shown in Fig. 6, which can perform efficient and accurate location of information 

25 within a collection of text-based information sources. Briefly, such a system is given access to 
one or more collections of text-based information sources 303a and 303b. At least one group of 
text-based information sources 303a is supplied to automatic linguistic knowledge base 
generatuig software 601, which generates the linguistic knowledge base 305 as described above. 
Text-based information sources 303b are provided to an indexing subsystem 603 which creates 

30 an index 401 of words in the text-based infonnalion sources 303b, in which each entry in the 
index 401 defines a relationship between a word and the location of the word in the collection, as 
described above. It is preferred that the index 401 be generated using normalized words in one 
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or more languages for which the system has a thesaurus 501 and a linguistic knowledge base 
305. The indexing subsystem 603 may include a module to recognize words having forms which 
conform to one of the languages supported by the system and may further include an appropriate 
normali^ng module for each language supported by the system. Words are normalized in their 
5 language as discussed above, to reduce the number of anomalous entries appearing in the index 
401 . The system further receives a user query 505 in the form of one or more words expressive 
of the information sought by the user. The query words are expanded 605 using a 2D expansion 
matrix, as discussed above. The query is first assodatively expanded to include words related to 
the original query words by reference to the thesaurus appropriate for the language of the query 
10 words. The associatively expanded query is then linguistically expanded in both the 

morphological and phonetic dimensions, simultaneously. The degree of expansion in each 
dimension is specified by the user, by parameters 511 supplied with the query. The degree of 
expansion may be specified by the user, for example, by attaching a checklist of expansion 
parameters 511 to each query term. Finally, the tenns of the fully expanded query 607 are 
15 compared 609 with the entries in the index 401 to find relevant locations 61 1 within the . 
collection of text-based information sources 303b. 

Relevant locations 61 1 in the collection of text-based information sources 303b do not 
necessarily contain any of the original query terms. By the processing described above, the 
locations found 61 1 will contain one of the original query temas or a related terni produced by 
20 the associative and linguistic expansion processes. The locations foimd 61 1 will not include 
many *'noise*' locations because the lingmstic expansion process is performed as described above 
in a manner in which the morphological and phonetic linguistic rules are applied simultaneously 
in a synergistic manner that avoids the problem of applying a morphological rule to generate a 
phonetically nonsensical result or vice versa. 
25 in a system such as described above, tiie text-based information sources may be text 

documents stored on a computer system. In this case, it may be convenient for tiie indexing 
system to hierarchically refer to locations by document number, section number, sentence 
number and position with the sentence. Furthermore, freely formatted text documents may be 
processed by the above-described system. There is no need to stmcture the documents a 
30 particular way or'to manually produce classifications or keywords, as done in some prior art 
systems, because the present system indexes words and manipulates queries according to the 
rules of the language in which the words occur. 
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If it is desired that a phrase be treated as a single word or term in a particular language, 
then that phrase may be so defined as a conceptual entity in a thesaurus. In all other respects, the 
phrase so defined as a word is treated simply as a word in the language. However, it is 
unnecessary to declare a long list of accepted keywords because the process of indexing and 

5 query expansion generates accurate, relatively noise-free matches for user queries reasonably 
expressive of the information sought. 

Having thus described at least one illustrative embodiment of the invention, various 
alterations, modifications, and improvements will readily occur to those skilled in the art. Such 
alterations, modifications and improvements are intended to be within the spirit and scope of the 

10 invention. Accordingly, the foregoing description is by way of example only and is not intended 
as limiting. The invention is limited only as defined in the following claims and the equivalents 
thereto. 
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1. A text-based infonnation processing system, comprising: 

an automatic linguistic knowledge base generator having an input receiving a collection 
5 of text-based information sources and which produces a linguistic knowledge base; 

an index generator having inputs receiving a collection of text-based information sources 
and the linguistic knowledge base and which produces an index of the received text-based 
information and further which updates the linguisUc knowledge base to reflect the inputs to the 
index generator and maintain correlation between the index and the linguistic knowledge base; 
10 and 

a query processor having inputs receiving a query composed by an operator, the linguistic 
knowledge base, the index and a thesaurus and which produces a list of locations in the 
collection of text-based information sources relevant to the query. 



15 



2. In a text-based information processing system, an automatic linguistic knowledge base 



generator, comprising: 

a parser, receiving an input stream of terms and producing individual terms; 
a language recognizer connected to receive the individual terms from the parser and 
which produces an ou^ul indicative of a language to v^ch each individual term belongs; 
20 a nonnalizer connected to receive the individual terms and further connected to receive 

linguistic niles for the language mdicated by the output of the language recognizer and producing 

normalized terms; and 

a rmguistic expander connected to receive the normalized terms and producing entries 

stored in the linguistic knowledge base. 

25 

3. The system of claim 2, wherem the nonmalizer further comprises: 
a first normalizer unit connected to receive the individual terms and the Imguistic rules 
and producing terms from which illegal characters have been removed; and 

a second normalizer unit connected to receive the terms from which Ulegai characters 
30 have been removed knd the linguistic mles and which produces normalized terms including word 
stems found by applying the linguistic rules to the temis from which illegal characters have been 
removed. 
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4. In a text-based information processing systeni, an automatic indexer, comprising: 
a parser, receiving an input stream of terms and producing individual terms; 

a language recognizer connected to receive the individual terms from the parser and 
which produces an output indicative of a language to which each individual term belongs; 

a nonnalizer connected to receive the individual terms and further coimected to receive 
linguistic rules for the language indicated by the output of the language recognizer and producing 
normalized terms; and 

an index generator having inputs receiving a collection of text-based information sources 
and the linguistic knowledge base and which produces an index of the received text-based 
information and further which updates the linguistic knowledge base to reflect the inputs to the 
index generator and maintain correlation between the index and the linguistic knowledge base. 

5. The system of claim 4, wherein the nonnalizer further comprises; 

a first normaiizer unit connected to receive the individual terms and the linguistic rules 
and producing terms from which illegal characters have been removed; and 

a second nonnalizer unit connected to receive the terms from which illegal characters 
have been removed and the linguistic rules and which produces normalized terms including word 
stems found by applying the linguistic rules to the terms from which illegal characters have been 
removed 

6. In a text-based information processing system, an expansion unit for expanding terms 
in a language, comprising: 

an associative expander having an input receiving a terni and having an output 
representing the term and at least one associated term found by the associated expander making 
reference to a thesaurus; and 

a linguistic expander having an input connected to the output of the associative expander 
and having an output representing *e input of the linguistic expander and at least one term 
linguistically related to the input of the linguistic 
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